草庐IT

C++ operator+ 和 operator+= 重载

全部标签

c# - UInt64 和 "The operation overflows at compile time in checked mode"- CS0220

这感觉像是一个愚蠢的问题,但我似乎看不到答案。我有一个UInt64,它的最大值应该是UInt64.MaxValue18446744073709551615但是,当我尝试分配一个中等大小的数字时,出现“在检查模式下编译时操作溢出”的溢出错误。如果我将它包装在一个“未经检查”的block中,那么它会编译并运行,就像这个变量为零一样:UInt64value1=1073741824*8;//CompileerrorCS0220UInt64value2=8589934592;//Actualvalue-noerror为什么会这样? 最佳答案

c# - 我可以重载 throw 关键字吗?

我想重载throw关键字以捕获继承自Exception的类,并让它在实际抛出之前执行一些日志记录和其他操作。这可能吗?还是我必须使用常规函数?我试过:publicclasscSilException:Exception{privatestringm_strMsg;publicoverridevoidthrow(cSilExceptionex){}......} 最佳答案 注册事件AppDomain.FirstChanceException.您可以在实际抛出之前获得所有异常。在事件处理程序中,您可以检查您的exception并执行所需

c# - 为什么 C# 编译器重载解析算法将具有相同签名的静态成员和实例成员视为相等?

让我们有两个签名相同的成员,但一个是静态的而另一个不是:classFoo{publicvoidTest(){Console.WriteLine("instance");}publicstaticvoidTest(){Console.WriteLine("static");}}但是这样的代码生成会带来编译错误:Type'Foo'alreadydefinesamembercalled'Test'withthesameparametertypes但为什么呢?让我们编译成功,然后:Foo.Test()应该输出“static”newFoo().Test();应该输出“instance”不能调用静

c# - 在继承类中重载方法

我已经开始明白我不明白发生了什么。在C#中有以下行为:publicclassBase{publicvoidMethod(Da){Console.WriteLine("publicvoidMethod(Da)");}}publicclassDerived:Base{publicvoidMethod(Ba){Console.WriteLine("publicvoidMethod(Ba)");}}publicclassB{}publicclassD:B{}classProgram{staticvoidMain(string[]args){Derivedderived=newDerived()

c# - 需要重载 operator< 和 null 检查

我在C#中重载了lessthan运算符,我想知道这是否需要检查null。您可以在下面找到一个示例:publicstaticbooloperator或者这是正确的:publicstaticbooloperator我没有找到任何关于此的说明。但也许我错过了什么。 最佳答案 答案取决于您的预期使用模式。如果您计划混合使用空值,并且您希望null值小于非空值,那么您的实现是正确的;如果您想将null值视为大于非null对象,则注释掉的返回值(false和true)应该被使用。如果您不打算在混合中允许空值,则抛出ArgumentNullExc

c# - C# 中方法重载的不同行为

我在浏览C#脑筋急转弯(http://www.yoda.arachsys.com/csharp/teasers.html)时遇到了一个问题:这段代码的输出应该是什么?classBase{publicvirtualvoidFoo(intx){Console.WriteLine("Base.Foo(int)");}}classDerived:Base{publicoverridevoidFoo(intx){Console.WriteLine("Derived.Foo(int)");}publicvoidFoo(objecto){Console.WriteLine("Derived.Foo(

c# - 反射(reflection)使用 out 参数的静态重载方法

我在通过反射调用带有out参数的重载静态方法时遇到一些问题,希望得到一些指示。我希望动态创建一个类型,如System.Int32或System.Decimal,然后调用静态TryParse(string,outx)方法。下面的代码有两个问题:t.GetMethod("TryParse",newType[]{typeof(string),t})未能返回我期望的MethodInfomi.Invoke(null,newobject[]{value.ToString(),concreteInstance})似乎成功但未设置输出参数concreteInstance到解析后的值交织到这个函数中,您

c# - 当不能简单地重载时混合可选参数和参数

类似于thisquestion,我想将可选参数与params关键字混合使用,这当然会产生歧义。不幸的是,创建重载的答案不起作用,因为我想利用调用者信息属性,如下所示:publicvoidInfo(stringmessage,[CallerMemberName]stringmemberName="",[CallerLineNumber]intlineNumber=0,paramsobject[]args){_log.Info(BuildMessage(message,memberName,lineNumber),args);}在没有可选参数的情况下创建重载会更改调用站点,从而阻止这些特定

c# - .NET对不同参数重载方法的误解(Call Ambiguous)

我有一些重载方法的问题,我会尝试给出一个简单的实现。所以这是一个包含以下两个方法的类:publicclassMyRepo{publicListGetData(Expression>expression){//Dosomething}publicListGetData(FuncwhereClause){//Dosomething}}这是我的实体:publicclassMyEntity{publicintId{get;set;}publicstringName{get;set;}}这里是我使用它的地方:{...MyRepomyRepo=newMyRepo();myRepo.GetData(

c# - .NET 4.5 中的代码契约 + 异步 : "The method or operation is not implemented"

在Windows7x64上的VS2012中使用CodeContracts1.4.51019.0时,我从ccrewrite收到以下编译错误:“方法或操作未实现."这似乎是由属性访问器的组合和使用缺少内部await的async方法引起的。复制步骤:创建一个启用“完整”运行时契约检查的新类库:namespaceCodeContractsAsyncBug{usingSystem.Threading.Tasks;publicclassService{//Offendingmethod!publicasyncTaskProcessAsync(Entityentity){varflag=entity